## Tentative Schedule for Software and Hardware Co-Design with Zybo -- Week 1 (As of 8-9-2021)

Monday to Saturday, August 9-15, 2021

| Day                                                   | 9:00-10:50am                                                                                                                                                                                    | 11:00-11:50 | 2:30-3:20pm Due date                                                        | 3:30-4:20pm | Handouts                                                                                                                                                                                                                              |
|-------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|-----------------------------------------------------------------------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1 Monday (August 9) Verilog Review Zybo Introduction  | <ul> <li>Lecture 1 Combinational and Sequential Circuits in Verilog</li> <li>Lab 0 Vivado installation and Gate3 implementation with Vivado</li> <li>Lab #0 and Homework #1 assigned</li> </ul> | 0           | 0                                                                           | 0           | <ul> <li>Lab #0 handout</li> <li>Lecture #0 and #1 PPT</li> <li>Gate3 project</li> <li>Detect011 project</li> </ul>                                                                                                                   |
| 2<br>Tuesday<br>(August 10)                           | <ul> <li>Lecture 2-1 Zybo, FPGA, PicoBlaze and UART Clock</li> <li>Lecture 2-2 ASM chart and Controller Design</li> <li>Lab #1 Xilinx Tool Flow and UART Clock</li> </ul>                       | 0           | ○ Lab #0 due                                                                |             | <ul> <li>Lecture 2-1 and 2-2</li> <li>Lab #1 handout and source files</li> <li>Homework #1handout</li> <li>problem8homework1UART documents.zip</li> <li>Four counters project.zip</li> <li>stopwatch2021summerlNexyA 7.zip</li> </ul> |
| 3<br>Wednesday<br>(August 11)<br>I2C Master<br>Module | <ul> <li>Lecture 3-1 Design of I2C Controller in Verilog</li> <li>Lab #2 Phase 1 I2C</li> </ul>                                                                                                 | 0           | <ul> <li>Lab #1 Xilinx Tool Flow and<br/>UART Clock due</li> </ul>          | 0           | <ul> <li>Lab2 phase 1 handout</li> <li>Lab2 phase 1 files</li> <li>Lecture 3-1 handout</li> <li>Lecture 3-1 worksheet</li> <li>TMP101 datasheet</li> </ul>                                                                            |
| 4<br>Thursday<br>(August 12)<br>TMP101                | <ul> <li>Lecture 3-2 Reading TMP101</li> <li>Lab #2 Phase 2 TMP101</li> </ul>                                                                                                                   | 0           | <ul><li>Lab 2 Phase 1 due</li><li>Homework #1 due</li></ul>                 | 0           | <ul> <li>Lab2 phase 2 handout</li> <li>Lab2 phase 2 template files</li> <li>Lecture 3-2 ppt</li> <li>Uarttypewriter project</li> <li>TransmitRAM2021summer project</li> </ul>                                                         |
| 5<br>Friday<br>(August 13)<br>Zynq Intro              | <ul> <li>Lectures 4-1 and 4-2 Introduction to Zynq, IO pins and memory</li> <li>Lab #3 part 1 and part 2 Block design and adding IP cores</li> </ul>                                            | 0           | o Lab #2 Phase 2 TMP101 due                                                 | 0           | <ul> <li>Lecture 4-1 and 4-2 ppt</li> <li>lab3summer2021SoC handout</li> <li>Lab Workbook ZYNQ Lab 1</li> <li>Lab Workbook ZYNQ Lab 2</li> <li>The Zynq Book</li> <li>ZYBO Reference Manual, 2014</li> </ul>                          |
| 6 Saturday (August 14) AXI4, IP, SDK, XDC, Timers     | <ul> <li>Lecture 6 Board definition, LED ip, drivers, Timers, Debugging</li> <li>Lab #4 part 1 and part 2 Add custom IP and write basic software</li> <li>Homework #2 assigned</li> </ul>       |             | <ul> <li>Lab #3 Parts 1 and 2 Block<br/>design and adding IP due</li> </ul> |             | <ul> <li>Lab 4 part 1 and part 2 handouts</li> <li>Lecture 5-1 and 5-2 ppt</li> <li>Homework 2 handout</li> </ul>                                                                                                                     |

## Schedule for Software and Hardware Co-Design with Zybo -- Week 2

Monday to Saturday, August 16-22, 2021

| Day                                                      | 9:00-10:50am                                                                                                                                                                                        | 10:30-11:30 | 2:30-3:20pm Due date                                                                       | 3:30-4:20pm | Handouts of the day                                                                              |
|----------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------------------------------------------------------------------------------------|-------------|--------------------------------------------------------------------------------------------------|
| 7<br>Monday<br>(August 16)<br>Interrupt<br>I2C Modules   | <ul> <li>Lecture 6 Board definition, LED ip, drivers,<br/>Timers, Debugging</li> <li>Lab #5 Software and Timer</li> <li>Lab #6 Ping Pong Game on Zybo with<br/>Polling</li> </ul>                   | 0           | <ul> <li>Lab #4 Add custom IP and write basic software due</li> </ul>                      | 0           | <ul> <li>Lab 5 handouts</li> <li>Lecture 6 ppt</li> <li>Lab 6 handout</li> </ul>                 |
| 7<br>Tuesday<br>(August 17)<br>UART IP<br>DMA, VGA       | <ul> <li>Lecture 7 LED Ping-Pong Game with<br/>Polling, sdk, XDC</li> <li>Lecture 8 Interrupts and interrupt-driven<br/>pingpong game</li> <li>Lab #7 Interrupt-driven Ping-Pong on Zybo</li> </ul> | 0           | o Lab #5 Software and Timer due                                                            | 0           | <ul> <li>Lecture 7 ppt</li> <li>Lecture 8 ppt</li> <li>Lab 7 handout</li> </ul>                  |
| 8 Wednesday (August 18) VGA, Color generation Bootloader | Lecture 9 ARM I2C Module and Driver,<br>UART ip Lab #8 I2C and UART with ARM modules                                                                                                                | 0           | Lab #6 Ping Pong Game on Zybo with Polling due                                             | 0           | <ul> <li>Lab 8 I2C handout</li> <li>Lecture 9</li> <li>xiicps_polled_master_example.c</li> </ul> |
| 9<br>Thursday<br>(August 19)<br>Embedded Linux           | Lecture 10 VGA and RBG color generation     Lab #9 VGA, Image Creation and Boot     Loader on Zybo                                                                                                  | 0           | <ul> <li>Lab #7 Interrupt-driven Ping-Pong on Zybo due</li> <li>Homework #2 due</li> </ul> | 0           | 0                                                                                                |
| 10<br>Friday<br>(August 20)<br>ARM Cortex A9<br>Lab #11  | <ul> <li>Lecture 11 Embedded Linux with Zybo and<br/>ARM Cortex A9 Architecture</li> <li>Lab #10 Embedded Linux with Zybo</li> </ul>                                                                |             | <ul> <li>Lab #8 2C and UART with ARM<br/>modules due</li> </ul>                            | 0           |                                                                                                  |
| 11<br>Saturday<br>(August 21)                            | Lecture 12 Device Tree, Ubuntu and Linux<br>Basics, software and hardware co-design                                                                                                                 | 0           | Lab #9 VGA, Image Creation and<br>Boot Loader on Zybo                                      | 0           | 0                                                                                                |
| 11<br>Saturday<br>(August 22)                            | 0                                                                                                                                                                                                   | 0           | Lab #10 Embedded Linux with Zybo                                                           | 0           | 0                                                                                                |